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Beschreibung 
15 - . .. - . :. 

Die vorliegende Erfindung betrif ffr-das oberbegrif f lich Bean- 
spruchte. Damit befaflt sich die vorliegende Erfindung mit 
Verbesserungen an Logikzellenarrays. 

20 Logikzellenarrays, insbesondere auch' rekonf igurierbare, sind 
bekannt. Zur Gattung dieser Bausteine zahlen insbesondere sy- 
stolische Arrays, neuronale Netze, Mehrpozessorsysteme, Pro- 
zessoren mit mehreren Rechenwerken und/oder logischen Zellen 
und/oder kommunikativen/peripheren Zellen (E/A, d.h. IO), 

25 Vernetzungs- und/oder Netzwerkbausteine wie z.B. Crossbar- 
Schalter, ebenso wie bekannte Bausteine cder Gattung FPGA, 
■ DPGA, Xputer, Chameleon etc.. Hingewiesen wird in diesem Zu- 
sammenhang insbesondere auf die folgenden auf die vorliegen- 
den Anmelder zuriickgehenden Schutzrechte, die zu Offenba- 

30 rungszwecken durch Bfezugnahme vol lumf&ng lich eingegliedert 
sind: DE 44 16 881, DE 197 81 412, DE 197 81 483, DE 196 54 
846, DE 196 54 593, DE 197 04 044, DE 198 80 129, DE 198 61 
088, DE 199 80 312, PCT/DE 00/01869, DE 100 36 627, DE 100 28 
397 DE 101 10 530, DE 101 11 014, PCT/EP 00/10516, EP 01 102 

35 674 sowie Familienmitglieder hierzui Lbgikzellen sind somit 
definiert als beliebige Logik und/ocier Arithmetik und/oder 
Schalter und/oder Speicher und/oder Peripherie beinhaltender 
Zellen* 

40 Wahrend ftir derartige Systeme im Stand der Technik, insbeson- 
dere dem vorstehend zitierten, eine Reihe von Ansatzen be- 
kannt sind, urn eine ef fiziente Verarbeitung von Daten prinzi- 
piell zu enrioglichen, und diese Ansatze auch gut in Hardware- 
Architekturen implementierbar sind, besteht bei der prakti- 

45 schen Omsetzung dennoch der Wunsch, moglichst gunstige Ausle- 
gungen zu gewahrleisten, die insbesondere platzsparend auf 
einem Wafer untergebracht werden und/oder energiesparend be- 
trieben werden kSnnen;' ilberdies ist es wilnschenswert, beson- 
ders vorteilhafte Arten des Betriebes zu finden. 



BESTATIGUNGSKOPIE 



WO 02/29600 



PCT/EP01/11593 



Eine der gravierenden Schwierigkeiten bei Systemen aus dem 
Stand der. Technik ist darinzu sehen,. . daft eine Vielzahl von 
Zellen miteinander kommunizieren mdssen. Die Kommunikation 
5 . kann erf brderlich seih, um zu bearbeitende Daten zwischen den 
Zellen zu iibermitteln. Dies ist etwa dann der Fall, wenn eine 
; Zelle die Ergebnisse aus einer arideren Zelle weiterverarbei- 
ten soli, z.B. durch Verkntipf ung 'des dort erhaltenen Ergeb- 
nisses mit von einer oder mehreren weiteren Zellen erhaltenen 
10 Ergebnissen. Weiter kknn Kommunikation erforderlich sein, um 
Statussignale zu libertragen. 

Zur Obertragung von Signalen an einen einer Vielzahl mogli- 
cher Empf anger sind Busse seit langem bekannt. Busse sind 
15 Bundel aus Leitun'gen, wobei die Anzahl der Leitungen typisch 
bestimmt ist aus der Zahl miteinander , d.h. typisch parallel 
zu ubertragender Bits,: zuzUgl. gegebenenf alls einer Reihe von 
Statusleitungen • 

20 Bei bekannten einfachen Bussen, wie sie z.B. in PCs zur Kom- 
munikation von Steckkarten mit der CPU und/oder untereinander 
verwendet werden, k5nnen die Bus-Leitungen zu alien Empf an- 
gem gefahrt werden und dann wird durch geeignete mitubertra- 
gene Steuersignale, d.h. Adressierung sichergestellt, daJJ nur 

25 diejenigen Empf anger ansprechen, die die Daten empfangen sol- 
len. Problematisch wird eine solche Anordnung dann, wenn sehr 
viele kommunzierende Einheiteh Zugriff auf den Bus bzw. die 
Busse benotigen. Es muB dann namlich erf orderlichenf alls mit 
der Kommunikation der Daten gewartet werden, bis der Bus von 

30 anderen Einheiten frei gegeben wurde und/oder es miissen Zeit- 
scheibenlosungen implement iert werden, die einer sendenden 
Einheit nur eine bestimmte Obertragungszeit einraumen, und 
zwar im Regelfall unabh^ngig davon, ob in dieser Zeit alle 
Daten Ubertragen werden, was evtl. auch erforderlich macht, 

35 mehrere Zeitscheiben fUr die DatenUbertragung aufzuwenden. . 
Dieser Ansatz wird etwa in Systemen wie dem Token-Ring- 
Netzwerk praktiziert. In Systemen wie Logikzellenarrays, in 
denen eine sehr schnelle Kommunikation gewilnscht ist, um hohe 
Datenverarbeitungsgeschwindigkeiten zu gewahrleisten, ist 

40 dies unerwanscht t 

Es ist auch schon vorgeschlagen worden, die Busse zu segmen- 
tieren. Wenn z.B. bei einer Reihe von Logikzellen mehrere 
miteinander zu verbindende Einheiten paarweise dicht beiein- 
45 ander liegen, kann eine langs aller Einheiten gefiihrte und 
somit lange Busleitung an Zwischenstellen vermittels von 
Schaltern aufgetrennt werden, um so mehrere Teil-Busssysteme 
zu bilden. Jedes Segment umfaBt dabei wie der Gesamtbus die 
erforderliche tozahl paralleler Daten-Leitungen und die zu- 
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satzlich notwendlgeh Protokollleitungen; die Kommunikation 
. .eines Paares dicht beieinander liegenden Logikzellen stort 

dann die Kommunikation eineis antler en, dicht beieinander lie- 
"' genden Paares nicht. So kann die Uber das Bussystem Ubertra- 
5 gene Datenrate wesentlich gesteigert werden. 

Problematisch ist allerdings, dafi, wenn derartige Bussyste- 
men, etwa in CMOS-Technik auf Hal'bleiterchips integriert wer- 
den, der Aufbau typisch komplex und der Betrieb energetisch 
10 ungunstig ist. 

Die Aufgabe der yorliegenden Erf indung besteht darin, Neues 
fur die gewerbliche Anwendung bereitzustellen. 

15 Die Losung dieser Aufgabe wird in unabhangiger Form bean- 

sprucht. Bevorzugte Ausfuhrungsformen finden sich in den Un- 
teransprtichen . . 

Ein erster wesentlicher Aspekt der vorliegenden Erf indung 
20 schlSgt somit vor, daS bei einer Logikzellenanordnung mit 
einer Anzahl Logikzellen und einem segmentierten Bussystem 
fur die Logikzellenkommunikation, vorgesehen ist, daS das 
Bussystem unterschiedliche Segmentlinien mit kurzeren und 
langeren Segmenten zur Verbindung zweier Punkte umfafit, urn 
25 die Anzahl zu durchlauf ender Buselemente bei auseinander be- 
abstandeten Kommunikationsstart- und Endpunkten gering hal- 
ten zu konnen. 

Damit nutzt die vorliegende Erfindung in einem ersten Grund- 
30 gedanken, daS sich durch Ausbildung der Busse mit als einfa- 
che Leitung gestalteten Segmenten grofier Lange fiir die Uber- 
briickung grofier St recken in einer Logikzellenanordung eine 
besonders einfache Ausgestaitung und ein besonders sparsamer 
Betrieb ergibt. Indem zugleich kurze Segmentlinien vorgese- 
35 hen werden, ist sichergestellt , daS dennoch alle Punkte wie 
erforderlich ansprechbar sind. 

Bevorzugt sind die Segmentlinien jeweils aus einer Mehrzahl 
paralleler Leitungen gebildet sind, deren Anzahl durch die 

40 Bus-Breite und/oder das Busprotokoll bestimmt ist. Es ist 

also jedes Segment durch ein Btindel paralleler Leitungen ge- 
bildet, so wie dies per se aus dem Stand der Techriik bekannt 
ist. Es versteht sich, daS dann alle Leitungen eines Segmen- 
tes im wesant lichen die selben Langen aufweisen; im wesent- 

45 lichen bedeutet dabei, dafi die Leitungen eines Leitungsbtin- 
dels alle zu ein und derselben Endpunktlinie wie einem Da- 
teneingang einer Logikzelle gef iihrt sein konnen, wo sie an 
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die ihnen bitweise zugeordneten Eingangsglieder gelegt wer- 
den konneru 

Es ist bevorzugt, wenn an datenverandernde Logikzellen wie 
5 kecheneinheiten drei der fur die verarbeitete Bitbreite er- 
f order lichen Leitungsbttndel als Datenzufuhrungsleitungen zu- 
gefuhrt sind. Dies erlaubt es, innerhalb der Zelle eirie Ver- 
knupfung von Operanden A, B, C der Art AxB+C vorzunehmen. 
Diese Operation ist ijn Bereich digitaler Signalverarbeitung 
10 von besonderer Bedeutung und die Busstruktur somit fur Lo- 
gikzellenarrays zum Aufbau echtzeitrekonf igurierbarer DSP- 
Arrays besonders g;eeignet. 

Es ist insbesondere bei Logikzellenanordnung, mit denen eine 
15 arithmetisch-multiplikative Verknupfung von Operanden vorge- 
nommen werden kann, besonders bevorzugt, wenn aus den Zellen 
wenigstens zwei der fur die verarbeitete Bitbreite erforder- 
lichen Leitungsbiindel filr Daten weggefiihrt sind, insbesonde- 
re mit einem Leitungsbiindel ftir hoherwertige und einem Lei- 
20 tungsbundel fur niederwertigere Bits; so kann bei einer Da^- 
tenwortbreite von 32 Bit ein 64 Bit breiter Ausgang erzeugt 
werden, urn das Ergebnis einer Multiplikation in voller Brei- 
te auszugeben. 

25 Bei rekonf igurierbaren Logikzellen ist es bevorzugt, wenn 

insbesondere tibar das segtnentierbare Bussystem Steuereingan- 
ge ansprechbar sind, die derart angeordnet sind, da£ wenig- 
stens die Steuersignale zur Ablauf steuerung in der Logikzel- 
le, wie z.B. die Signale Reset, Step, Stop, Go und Reload in 

30 die Zelle libertragbar sind. Mit diesen wird ausgeldst 

und/oder ermoglicht ein'Zuriicksetzen, eine Umkonf igurierung 
und eine Aktivierung. Dazu kiann eine entsprechende Anzahl 
voii Bitleitungen vorgesehen werden; bevorzugt werden daher 
wenigstens zwei Bit breite Datenleitungen ffir Steuersi- 

35 gnaleingange vorgesehen . Es ist besonders bevorzugt, wenn 

jedem der steuernden Signale ein separater Signaleingang zu- 
geordnet ist; alternativ kann eine Eingangsverkniipfungschal- 
tiing auf einer mehreren Bit breiten Statusleitung fur ein 
ordnungsgem&Ses Ansprechen der Zelle sorgen. Diese Steuersi- 

40 gnaleingange sind insofern Steuersignaleing&nge, als fiber 

sie die konf igf^rations- uhd/oder Rekonf igurationssteuernden 
(Kontrollf lufc-) Signale, insbesondere Triggersignale wie aus 
dem vorerwcLhnteii Stand der Technik bekannt, an die Zelle ge- 
leitet werden konneri. Die eigentliche Kommunikation der Zel- 

45 le mit der Oder einer umkonf igurierenden Einheit wie einem 
Konf igurationsmdnager (CT bzw. CM) kann dabei in per se be- 
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karinter Weise z.B. Qber das sog. Ready /Ack/Re j -Protokoil er- 
folgen, das eine Urnkonf iguration der Zelle nur unter be-, 
s.timmten Bedingungen erlaubt . Ftir die Einzelheiten dieser 
Protokolle wird auf die einleitend durch Bezugnahme vollum- 
5 f anglich eingegliederten Schutzrechte des Anmelders urid jed- 
wede weiteren offentlich zuganglichen Dokumente iiber die 
XPP/VPU-Architektur verwiesen. 

Das Bussystem kann Secjmente zur Verbindung der Logikzellen 
10 untereinander umfassen; dies ist der typische Fall und des- 
halb von besohderer Bedeutung, weil innerhalb des Logikzel- 
lenarrays ein besonders hoher und ef f izienter Datendurchsatz 
bendtigt wird, ohne dafi sich der Prozessorbaustein etwa 
durch hohe Verlustleistungen aufheizen soil. Hier ist die 
15 - vorliegende Erfindung besonders effizient einsetzbar. 

Alternativ und/oder zuscLtzlich kann das Bussystem an interne 
. und/oder externe die Logikzellen konf igurierenden und/oder 
rekonf igurierenden Einheiten geftihrt sein; die Busse konnen 

20 insbesondere an einer Vielzahl von datenverarbeitenden 

und/oder speichernden Logikzellen vorbei zu einer Oder meh- 
reren solchen- (re-) konf igurierenden Einheiten gefiihrt sein, 
so da£ entweder eine Kommunikation der Zellen untereinander 
und/oder mit der oder einer konf igurierend Einheit moglich 

25 ist. Es sei in diesem Zusammenhang erwahnt, daS prinzipiell 
ein simultanes Aussenden von Inf ormationen an mehrere Emp- 
fanger moglich ist, etwa, urn im Falle des Bootens alle Zel- 
len gleichzeitig. zuriickzusetzen. Die Busstruktur kann dafur 
entsprechend ausgebildet sein. 

30 . • 

Weiter ist es bevorzugt und moglich, wenn das Bussystem zu 
I/O-Schnittstellen und/oder zu externen Datenspeichern ge- 
fiihrt ist . Es kann mit anderen Worten die Segment ierungs- 
struktur sowohl innerhalb als auch au£erhalb des Logikzel- 

35 lenfeldes mit Gewinn genutzt werden. 

I/O-Schnittstellen ubertragen bausteininterne Bussysteme 
nach extern. Dabei werden beliebige Bussysteme ggf . zeitlich 
alternierend zur externen Aus- und/oder Eingabe geschaltet. 
Zusatzlich kann die Moglichkeit bestehen mehrere Bussysteme 

40 derart zusammenzuf assen, dass diese aufeinander synchroni- 
siert werden. Beispielsweise konnen je zwei Ausgabebussyste- 
me oder ein Eingabebus und ein Ausgabebus zusammen synchro- 
nisiert werden. 

45 In einer praktischen Ausfiihrung des Bussystem sind eine Rei- 
he von Leitungszwischenelemente vorgesehen; Leitung meint 
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hiefbei insbesondere einen Leiter erster Klasse, wie eine 
durchgehende Metalllinie in einem Halbleiterwafer . Leitungs- 
zwischenelemente me int. sol che . Element e,, die zwischen je zwei 
einander zugeordneten Leitungen angeordnet sind. Bei den 
. 5 Leitungszwischenelemente karin essich zurri eineri handeln urn 
Verbindungs- Schalter, die insbesondere im Ansprechen auf An- 
f orderungen von Logikzellen und/oder die Kommiinikatioh der- 
selben und/oder anderer Einheiteh vorgebenden Kontrollmit- 
teln; so kann der Schalter z.B. im Ansprechen auf eine An- 

10 forderung eines Konf igurationsmanagers, d.h. einer das Lo- 
gikzellenfeld konf igurierenden Einheit geschlossen oder ge- 
dffnet sein oder werden. Dies erlaubt es insbesondere, wie 
bevorzugt, mit einem Compiler festzulegen, wie die Busstruk- 
tur aufgebaut werden soli; insbesondere kann der Compiler 

15 oder eine aridere koiif igurierenden oder kontrollierende Ein- 
heit festlegen, ob die Kommunikat ion zwischen zwei beabstan- 
deten Zellen uber Segmentlinien mit kilrzeren oder langeren 
Segmenten erfolgen soil, und bei Vorhandensein mehrerer lan- 
gerer Segmente kann ftberdies auch bevorzugt vorgegeben wer- 

20 den, uber welche einer Vielzahl von Segmentlinien die Kommu- 
nikation erfolgen soil. Es kann damit der Lei stungsver lust 
uber die Schalter minimiert werden und/oder es kann eine op- 
timale Anpassung der Datenbe- und/oder -verarbeitung an Si- 
gnallaufzeiten langs der Busleitungen vorgesehen werden. 

25 

Die Leitungszwischenelemente konnen weiter und/oder alterna- 
tiv Multiplexer unifassen, urn ein Signal von einer Leitung an 
eine einer Reihe von Zielen wie Logikzellen und/oder weiter- 
ftihrenden Leitungen auf zuschalten und/oder, urn es auf eine 
30 Vielzahl von Zielen insbesondere wahlbare Ziele simultan zu 
speisen. 

Weiter kdhnen als Leitungszwischenelemente Register vorgese- 
hen sein. Diese erfiillen unterschiedliche Aufgaben. So kon- 

35 nen zunachst Daten auf dem Bus gehalten werden, bis ein Ziel 
bereit ist, diese abzurufen. Weiter kann bei Bussen, die 
sehr lang sind, vermieden werden, daS die Datenverarbeitung 
nur dann geordnet abl&uft, wenn die bei langen Strecken lan- 
gen Dauern bis zur Arikunft der Daten am Ziel (und gegebenen- 

40 falls dem Riickl^uf der Empf angsbestatigung). berucksichtigt 
werden. Indem Daten in Registern zwischengehalten werden, 
erh6ht sich zwar die Gesamtzeit (delay) , bis ein Datenpaket 
iiber den Bus gelaufen ist, aber die Zwischenzeit bis zur an- 
kunft der Daten (latency), in der' das Array bzw. einzelne 

45 Zellen nicht sinnvoll genutzt werden konnen, sind verrin- 

gert. Es sei darauf hingewiesen, dafi hier wiederum ein AbwS- 
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gen zwischen Latency und Delay erf orderlich sein kann, wobei 
das Register z.B. nur unter vorbestimmten und/oder festge- 
legten Bedingungen wie sehr langer Busstrecke zugeschaltet 
wird. Es ist darin wiinschenswert , wenn die Registerzuschal- 
.5 tuhg gesteuert wird, z;B. durch eine Kohtrolleinheit oder. 
ahnliches wie einen Konf igurationsmanager, der wiederum im 
Ansprechen auf cbmpilergenerierte Befehle arbeiten kann. 
Weiter ist es sinnvoll, ein Register vorzusehen, um ein syn- 
chrones Ankommen von Bits unterschiedlicher Wertigkeit an 

10 einem Zielpunkt zu gewahrleisten. Wehn Busse riickwarts ge- 
fuhrt sind 7 alsd eine Verbindung von einem Zellausgang zum 
Eingang derselben Zelle vorsehen, ist es besonders bevor- 
zugt, Register einzusetzen, weil so hochf requente Ruckkopp- 
lungen, die Bauteilzerstorend sein k6nnen, durch die regi- 

15 sterbedingte Delayzeit vermieden werden konneri. 

Register konnen jeweils oder teilweise in einer besonders 
bevorzugten Variahte als addierendes und/oder multiplizie- 
rendes Register ausgebildet sein; bestimmte Verknupfungen 

20 lassen sich problemf rei und mit geringem Schaltungsaufwand 
implementieren und so kanh netto die Logikzellenstrviktur 
durch Verlagerung einfacher Verknupfxingsaugfgaben entlastet 
werden. Insbesondere kann ein Register dazu ausgebildet 
sein, genau zwei Operanden algebraisch zu verkniipfen; bei 

25 Bussen zur Ubertragung von Statussignalen, die den Status 
einer oder einer Reihe von Logikzellen signalisieren 
und/oder dessen Anderung auslosen, d.h. bei Bussen fur sog\ 
Triggervektoren, konnen die Register bevorzugt dazu ausge- 
legt sein, Boolsche Verkniipfungen und/oder Nachschautabel- 

30 len, insbesondere veranderbare Nachschautabellen, zu imple- 
■ mentieren. ■ 

Als weitere, bevorzugt gleichfalls wahlweise zuschaltbare 
Leitungszwischerielement k6nnen Leitungstreiber vorgesehen 
35 sein. Dies kann insbesondere fir Multiplexanordnungen erfo- 
derlich sein, die ein starkes Signalauf f achern (fanout) vor- 
sehen . 

In einer besonders bevorzugten Variante der Erfindung ist es 
40 m6glich, langs eines Datentibertragungspf ades einen Wechsel 
von einer Segmentlinie mit langeren auf eine Segmentlinie 
mit kiirzeren Segmenten und/oder umgekehrt vorzusehen. Dies 
erlaubt es, bei Kommunikation einer grSSeren Zahl von Zellen 
in dieselbe Richtung, d.h. langs der selben Busstruktur, 
45 durch entsprechende Kombination kurzer und langer Segmente 
etwa gleiche Signallauf zeiten auch dann vorzusehen, wenn 
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Zwischenregister vorgesehen sind. Vergleichbar ist die Bus- 
struktur dabei mit einer StraSe, die Schnellspuren und 
Kriechspuren aufweist und an vorgegebenen Zwischenstellen 
einen Spurwechsel ermoglicht. 

Bevorzugt ist es allgemein, wenn das Bussystem eine Vielzahl 
von parallelen Segmentlinien uirif afit , wobei mehrere parallele 
Segmentlinien mit langeren Segmenten vorgesehen sind. Die 
langeren Segmente der Segmentlinien mit langeren Segmenten 
10 brauchen nicht alle gleichlang sein; es kann eine Staff elung 
vorgesehen sein. 

Bevorzugt ist es allgemein weiter, wenn bei einer groSer en 
Anzahl von parallelen Segmentlinien die Segmentlinienenden 

15 und/ oder Leitungszwischenelemente in den Segmentlinien in 
Busrichtung versetzt gegeneinander angeprdnet sind. Typisch 
sind an den Segmentlinienenden bzw. -anfangen Leitungszwi- 
schenelemente wie Schalter, Register, Multiplexer und Trei- 
ber vorgesehen. Die hardwaretechnische Implement ierung die- 

20 ser Elemente erfordert nun erheblichen Raum, der gegenuber 
dem von den in Zwischenschichten anzuordnenden Leitungen be- 
achtlich sein kann. Die bevorzugte versetzte Anordnung die- 
ser Elemente sorgt nun dafur, da£ nur Raum fur Leitungszwi- 
schenelementanordnungen von z.B. zwei oder drei Segmentlini- 

25 en erfoderlich ist, nicht jedoch fur Leitungszwischenelemen- 
tanordnungen aller vorhandenen Segmentlinien. Auch ist es 
mogoich, nicht bei alien Leitungszwischenelementanordnungen 
Treiber oder Register vorzusehen, sondern diese nur jedes 
n.-tes Segmentende vorzusehen . Bevorzugt ist jedoch dann, daS 

30 wenigstens drei Segmentlinien mit langeren Segmenten fur we - 
nigstens zwei Segmentlinien bei vorgegebenen Stellen Seg-- 
mentlinienwechselkreise angeordnet werden, insbesondere Mul- 
tiplexer, als Leitungszwischenelemente vorgesehen sind. So 
kann der gewunschte Segmentwechsel wie erforderlich gestal- 

35 tet werden. Bevorzugt ist die Busstruktur einem Zopf aus ei- 
ner Vielzahl sich immer wieder kreuzender Strahnen ver- 
gleichbar, wobei an den Strahnenkreuzungen ein Segmentwech- 
sel erfolgen kann und Wechsel unter langs des Busses vaxi- 
iernden Segmentpaaren oder Segment gruppen moglich sind. Es 

40 ist dann moglich und bevorzugt, da£ die Segmentlinienwech- 
selkreise fiir den Wechsel von einer ersten auf eine zweite 
Segmentlinie an einer ersten Stelle und die Segmentlinien- 
wechselkreise fur den Wechsel von einer zweiten auf eine 
dritte Segmentlinie an einer zweiten Stelle vorgesehen sind. 

45 
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Neben detri hur paarweisen Wechsel wird bevorzugt auch die 
Mqglichkeit geschaffen, an einer Stelle oder einer Vielzahl 
von Stellen unter mehreren Segment lini en zu wahlen, auf die 
gewechselt wird und/oder auf welche simultan Daten aufgege- 
5 ben werden. 

In einem weiteren Aspekt der vorliegenden Erfindung wird der 
Logikzellenanordnung die Kommunilcation der Zellen in zwei 
Richtungen moglich. Bei Busanordnungen mit Leitungszwi- 

10 schenelementen wie Treibern und/oder Registern sind Lauf- 
. richtungen definiert; urn die Kommunikation der Zellen in 
zwei Richtungen zu ermoglichen, sind daher bevorzugt ge- 
trennte Busanordnungen fur entgegengesetzte Lauf richtungen 
vorgesehen. Wenigstens in einer Richtung konnen wiederum fur 

15 wenigstens unterschiedliche, insbesondeire wiederum allgemein 
parallel g;efuhrte Segmentlinien rait kurzeren und langeren 
Segmenten vorgesehen sind. 

Bei getrennten Segmentlinien fur beide Lauf richtungen ist 
20 bevorzugt fiir wenigstens eine Lauf richtung Register vorgese- 
hen, bevorzugt ist dabei, wie vorstehend erlautert, das Re- 
gister im ruckwartsgefuhrten Bussystem vorgesehen, d.h. je- 
nem Bussystem, mit denen Signale von einem Elementausgang zu 
einem Elementeingang zuruckgefiihrt werden konnen. 

25 

Es sei erwahnt, da£ gemafi einem weiteren Aspekt der vorlie- 
genden ein erstes Bussystem fur die Ubertragung zu bearbei- 
tender Daten und ein zweites Bussystem fur die Ubertragung 
von Status- und/oder Kontroll-bzw. Steuerinf ormation voirge- 

30 sehen sein kann; wiederum kann ein oder beidie Bussysteme mit 
kurz.en und langen Segmenten auf weisenden Segmentlinien ge- 
bildet sein und es konnen bevorzugt die jeweiligen Bussyste- 
me bzw. Busanordnungen separat voneinander konf igurierbar, 
d.h. in ihrer Verschaltung festlegbar und/oder hinsichtlich 

35 der Operationen in verkhupfenden Registern bzw. der Ausgabe 
von Nachschautabellen bestimrnbar sein. 

Im Regelfall wird das Bussystem bevorzugt Einsatz finden bei 
einer Logikzellenanordnung, bei welcher eine Mehrzahl von 
40 Logikzellen in Reihe nebeneinander angeordnet sind; es sind 
dann die die langeren Segmente an wenigstens einer Logikzel- 
le vorbeigefuhrt; umfaSt die Logikzellenanordnung noch mehr 
Logikzellen in einer Reihe, sind bevorzugt die langsten Seg- 
mente an mehr als einer Logikzelle vorbeigefuhrt. 

45 
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Es sei darauf hingewiesen, daS bei wenigstens zweidimensio- 
nalen Logikf eldern, also wenigstens reihen- und spaltenwei— 
. ser Anordnung yon Logikzellen, . in jeder Reihe. und. in jeder 
Spalte ein segmentiertes Bussystem vorgesehen sein kann, das 
5 die vorbeschriebene Struktur mit langen und kurzeri Segment en 
in parallelen Segmentlinien aufweist. 

Die beschriebene Busstruktur ist vorteilhaf t bei alien An- 
ordnungen, bei welchen datenverarbeitende also Logik- 

10 Einheiten miteinander verkupft werden sollen. Besondere Vor- 
teile bieten sich aber, wenn die Logikzellen ausgewahlt sind 
aus, umfassen und/oder bilden Rechenwerke/DPGAs, Kress - 
Arrays, systolische Prozessoren und RAW- Ma chines; digitale 
Signalprozessoren (DSPs) , die mehr als ein Rechenwerk besit- 

15 zen. r konf igurierbare (programmierbare) Logikzellen oder an- 
dere Cores und/oder PAEs, ALU, Eingabe- / Ausgabefnnktionen 
(I/O) nhd/oder Speichermanagementeinheiten (I/O), Speicher. 
Eine erf olgreiche Implement ierung einer Busstruktur mit Seg- 
mentlinien mit kurzen und langen Segmenten ist die VPU / 

20 XPP-Prozessoreinheit des Anmelders. 

Ein solcher Prozessor wird bevorzugt eine Vielzahl unter- 
schiedlicher, in einem Array angeordneter kommunizierender 
Logikeinheiten aufweisen, wobei die Logikeinheiten wenig- 

25 stens Speicher- und Datenveranderungseinheiten aufweisen und 
die Speichereinheiten randnah am Array angeordnet sind. Dies 
erlaubt es, Daten durch das Array laufen zu lassen und am 
Rand erforderlichenf alls zwischenzuspeichern, urn eine Umkon- 
figration wie erforderlich zu bewirken. Das Durchlaufen kann 

30 auch durch parallele Reihen oder Spalten erfolgen und/oder 
auf maandernxie Welse,. urn so exhohte Rechenleistung bereitzu- 
stellen. 

Auch konnen allenfalls Eingang/Ausgangseinheiten naher am 
35 Rand als die Speichereinheiten angeordnet sein; dies erlaubt 
die Zwischenspeicherung von Daten vor Verarbeitung unter 
Arraydurchlauf • In jedem Fall wird aber bevorzugt, wenn zur 
Kommunikation der Logikeinheiten wenigstens von Rand zu Rand 
wenigstens ein Bussystem vorgesehen ist, das insbesondere 
40 segmentierbar ist wie vorbeschrieben. Dann ist es moglich, 
wenn zum Betrieb eines Prozessors Daten aus einem ersten 
randnahen Speicher ausgelesen und in einer erste, diesem 
Rand nahe Datenverandenmgseinheit wie erforderlich veran- 
dert werden, von dort in wenigstens eine weitere Datenveran- 
45 derungseinheit ubertragen werden, um weitere Datenverande- 
rungen wie erforderlich vorziuiehmen, die Daten nach Durch- 
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laufen mehrerer Datenveranderungseinheiten in einen zweiten. 
randnahen Speichern an einer vom ersten Speicher entfernten 
Stelle eingespeichert werden, eine Umkof igurierung der Da- 
tenveranderungseinheiten zur Neubestimmung der Datenverande- 
5 rung vorgenorameh wird und.. die Da ten ggf . in entgegengesetzer 
Laufrichtung durch zumindest einen Teil der Datenverande- 
rungseinheiten gefuhrt werden. Auch kann dann zum Betrieb 
vorgesehen sein, da£ der Hinlauf in einer Reihe erfolgt und 
der Rucklauf in der bzw. einer darunter liegenden Reihe, urn 
10 so Pipelineeffekte zu berucksichtigen. 

Der Prozessor kann wenigstens ein programierbares Gatterf eld 
(PGA)" und mehrere Datenveranderungseinheiten mit ALUs auf- 
weisen, wobei anwendungsspezif isch bevorzugt sein kann, wenn 
15 wenigstens eine oder mehrere PGAs von anderen Datenverande- 
rungseinheiten, insbesondere ALUs umgeben sind, urn von die- 
sen leicht Daten zu Verknupfungszwecke erhalten und/ oder an 
diese ausgeben zu konnen. 

20 Es ist moglich, daS bei einem Array aus rekonf igurierbaren 
Einheiten mehrere miteinander in Koiranunikation bringbare 
insbesondere identische (Teil-) Arrays vorgesehen sind. 
Hierzu kann jeweils eine Umkonf igurierungseinheit vorgesehen 
sein, die zur Umkonf igurat ion der umkonf igurierbaren Elemen- 

25 te des Arrays ausgebildet sein kann. Innerhalb des Arrays 
verlaufen dann die entsprechend vorstehend beschriebenen 
Busstrukturen. Es ist damit jedem Array eine Umkonf igurie- 
rungsverwaltungseinheit zugeordnet ist, die insbesondere an 
einer Arrayseite angeordnet sein kann, an welcher keine 

30 Speicher- und/oder I/O-Einheiten vorgesehen sind, wobei sich 
die Umkon f i gur ierungs einhe±t bevorzugt ukex die Breite des 
Arrays erstreckt, was den Vorteil bietet, da£ eine optimale 
Chipf orm erzeugt werden kann. 

35 Es ist dann wahlweise eine den Arrays gemeinsame Umkonf igu- 
r ierungs verwaltungsubereinheit vorgesehen, die sich insbe- 
sondere uber die Breite von mehr als einem Array erstreckt 
und die fur die Kommunikation mit zumindest mehreren, bevor- 
zugt alien der Umkonf igurierungsuberienheiten ausgelegt ist. 

40 

Alternativ und/oder zusatzlich ist es moglich, bei einem 
solchen Prozessor mit miteinander • in Kommunikation bringba- 
ren, insbesondere identischen Arrays, die umkonf i gur ierbare 
Datenveranderungseinheiten aufweisen, zwischen den Arrays 
45 Vermittlungseinheiten (VPAEs) vorzusehen sind, die zur Kom- 
munikationsvermittlung unter den Feldern angeordnet sind. 
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Uber solche Vermittlungseinheiten (VPAEs) konenn Daten 
und/oder Steuersignale (Kontrollsignale, Triggervektoren 
usw. ) ubertragen werclen. 

5 Es ist moglich, daB die Konf iguratidnseiiiheiteri ybh wenig- 
stens zwei der Arrays direkt in Verbindung miteinander ste- 
hen. Es kann dadurch auf eine . uberwachende (supervising) 
Konfigurationseinheit verzichtet ' werderi und/oder eine Aus- 
fallsicherheit erhoht werden. Bevorzugt wird dazu die Kommu- 
10 nikation der Konf igurationseinheiten der wenigstens zwei 
Arrays, die direkt in Verbindung miteinander stehen, uber 
dedizierte Festleitungen und/oder uber beim Booten vorkonfi- 
gurieirte d.h. festgelegte Datenleitungen bestimmt. 

15 Es sei erwahnt, date eine mogliche und bevorzugte Ausbildung 
der Vermittlungseinheiten (VPAEs) darin best eht # dafi diese 
zwei Konf iguraitionsregister auf weisen, wobei das erste Kon- 
f igurationsregister vom ersten Array und das zweite Konf igu- 
rationsregister vom zweiten Array ansprechbar ist. Nur wenn 

20 fur beide Arrays der Zugrif f auf die Vermittlungseinheiten 
zugelasen wurde, werden demnach Daten ubertragen, Dazu kann 
das erste Array das Einstellen von Daten in die Vermitt- 
lungseinheiten durch entsprechende Konf igurierung des ersten 
Konfigurationsregisters zulassen und das Einstellen der Da- 

25 ten der anderen Konf igurationseinheiten uber die dedizierte 
Leitung signalisieren. Danach sind die Daten abholbar, was 
durch Konf igurierung des zweiten Konfigurationsregisters be- 
stimmbar ist. Insgesamt wird so ein schleusenartiges Uber- 
tragen von Daten durch die VPAEs ermoglicht. Die Trennung 

30 eines groSeren Arrays in Teilarays erlaubt im ubrigen insge- 
samt-di e Vexringerung des von einer Konf igurati onRpj nheit 
handzuhabenden Konf igurationsaufwandes und kann dadurch zu 
einem ef f izient en Arraybet r ieb beitfagen, der nicht durch 
einen Konfigurationseinheit bedingten Engpass beeintrachtigt 

35 ist. 

Es ist einleuchtenderweise bevorzugt, wenn die Teil-Arrays 
uber eine mehrere Datenveranderungs- und/oder - 
transfereinheiten (VPAE) miteinander in Komunikation bring- 
40 bar sind, um so auch hier keine Datenratenbeschrijikung bei 
der Datenverarbeitung zu erzeugen. 

Bevorzugt ist es, in der geometrischen Hardware- 
Implement ierung der beschriebenen Anordung, wenn die kommu- 
45 nikationsermoglichenden Datenveranderungseinheiten beidseits 
uber langs des Arrays verlauf ende Busse an das Array ver- 
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bindbar sind, wobei die Busse insbesondere uber den Array- 
rand hinauslaufend ausgebildet und dort insbesondere weiter 
zu I/O-Schnittstelleneinheiten fuhrbar sein konnen. .. 

5 Wie vorsteherid erlautert , ist es besonders bevbrzugt , wenn 
im Prozessor ein oder mehrere Datenweiterleitungsregelimple- 
mentierungsmittel, insbesondere eine Nachschautabelle vorge- 
sehen ist/sind, das zur Ermoglichnng der Datenweiterleitung 
und insbesondere Datenubersetzung im Ansprechen auf die ge- 

10 meinsame Erfullung einer Vielzahl von Kriterien, insbesonde- 
re ereignisbezogener Kriterien ausgebildet ist. Bei den Wei- 
terzuleiteriden Daten kann es sich insbesondere urn Daten bzw. 
Triggervektoren handeln, die mit der Umkonf igurierung 
und/oder Umkonf igurierbarkeit von Logikzellen zu tun haben. 

15 Die Funktion bzw. die Ubersetzung des jeweiligen Datenwei- 
terleitungsregelimplementierung;smittel wird entsprechend 
konf iguriert . 

Es ist moglich, den Prozessor auch und gerade mit segraen- 
20 tierten Busstrukturen so aufzubauen, dafi Datenveranderungs- 
einheiten und Datenspeichermittel vorgesehen sind, wobei zu- 
mindest einigen der Datenveranderungseinheiten Datenspei- 
chermittel lokal zugeordnet sind, und insbesondere Mittel 
vorgesehen sind, urn in die lokalen Datenspeichermittel lokal 
25 eingeschriebene Daten zur lokalen neuer lichen Datenverande- 
rung lokal auszulesen. Mit anderen Worten konnen in einer 
Logikzelle Zwischenergebnisse gespeichert werden und mit an- 
deren Daten und/oder unter Verwendung anderer Verknupfungen 
weiterverarbeitet werden. 

30 

Wenn eine Umkonf igurierung. eines Zellarrays aus im Betrijeb 
rekonfigurierbaren Logikzellen erfolgt, das insbesondere ei- 
ne Umkonf igurierung im Anspreschen auf die Propagation be- 
stimmter vorgegebener Daten erlaubt, wie dies in der die Wa- 

35 ve-Rekonf iguration beschreibenden und unter Bezug genommen 
Verof fentlichungen insbesondere Schutzrechtsanmeldungen des 
vorliegenden Anmelders tun, so ist besonders bevorzugt, wenn 
auswahlbar ist, ob die Rekonf iguration im Ansprechen auf die 
Datenpropagation fur alle Logikzellen erfolgt, die von den 

40 vorgegebenen und/oder daraus hergeleiteten Daten angestromt 
werden und/oder nur fiir einen Teil, insbesondere einen Ver- 
arbeitungszweig (zB einen if -then-Zweig) , wahrend wenigstens 
ein anderer Zweig unverandert bleibt, was den Umkonf igurati- 
onsaufwand verringert und/oder nur eine Teilkette einer lan- 

45 geren Reihe von insbesondere nacheinander Daten verarbeiten- 
den Logikzellen insbesondere bis zu einer vorgegebenen Lo- 
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gikzelle umkonf iguriert wird, und/oder, uim die Rekonf igura- 
tion sofort oder.nach der bzw. einer weiteren Datenverarbei- 
tung zu gestatten . Dies erhoht den praktischen Nutzen der 
Wave -Rekonf igurat ion wesentlich. Es sei erwahnt, daS eine 
5 solche se lekt ive Wave -Umkonf igur ieruiig unter Verwenduhg voh 
nur wenigen Befehlen moglich ist, insbesondere z.B. den Be- 
fehlen Reset, Step, Stop, Go, Reload. Dement sprechend kann 
die Anzahl der an eine umkonf igurierbare Logikzelle wie eine 
PAE gefuhrter Trigger- bzw. Steuereingange gering sein. 

10 

Es sei als besonders vorteilhaft und bevorzugt erwahnt, daS 
die Art und Weise, wie eine Logikzelle auf ein bestimmtes 
charakteristisches Datenpaket bei Wave -Rekonf igurat ion rea- 
giert, vorladbar sein kann und/pder ist. Das kann insbeson- 
15 deere durch Vorladen der Nachschautabellen geschehen, die in 
den Bussen vorgesehen sind. Die Busse konnen dabei zum Teil 
durch Logikzellen gefuhrt sein und/bder von und/oder mit 
diesen gebildet sein. 

20 Es ist ohne weiteres moglich, die Prozessoranordnung mit dem 
Bussystem der vorliegenden Erf indung zu nutzen, urn bei Be- 
rechnungen das Verhalten nichtlinearer Systeme schnell und 
einfach zu approximieren. Dies geschieht bevorzugt, indem 
fur eine Reihe aneinander angrenzender Arbeit sbereiche je- 

25 weilige geeignete Approximationen bestimmt werden, zu einem 
augenblicklichen Arbeitsbereich (n) sowie zu dessen unten 
und oben ((n-1), (n+1) ) angrenzenden Arbeitsbereichen die 
Approximationen ermoglichenden Parameter vorgeladen werden, 
das Verhalten mit dem mittleren (n) Arbeitsbereich approxi- 

30 miert wird, bis der Arbeitsbereich, innerhalb dessen die Ap- 
proximation geeignet ist, uberschritten wird, dann mit jener 
der Approximation (n-1) weiter gearbeitet wird, welche zu 
dem Arbeitsbereich gehort, in welchen hinein die Dberschrei- 
tung erfolgte xmd bevorzugt die Approximation zu jenem Ar- 

35 beitsbereich (n+1) , in welchen hinein die Uberschreitung 
nicht erfolgte, uberschrieben wird mit einer Approximation 
(n-2) , die gemeinsam mit der zuvor verwendeten Approximation 
(n) die derzeit verwendete Approximation (n-1) bzw. die zu- 
gehorigen Arbeit sbereiche umklammert. Durch das Uberschrei- 

40 ben jenes Arbeitsbereichs, in welchen der Arbeitswert nicht 
gelaufen ist, brauchen bei eindimensionalen Fallen nur drei 
Variant en vorgeladen zu sein, urn eine schnelle Weiterverar- 
beitung nach Bereichsuberschreitung zu sichern. Da das Uber- 
schreiben des vorgeladenen Arbeitsbereiches wahrend der Da- 

45 tenverarbeitugn geschieht, ist bei stetigem Ubergang der Ar- 
beits-Werte ohne gr5£ere Sprunge oder steile Anderungen eine 
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konstante Datenberechnung moglich. Es sei als einleuchtend 
erwahnt, daS sich diese Art der Approximation auf mehrdimen- 
sionale Falle durch, Arbeitswertumklammerung in mehr , als ei- 
ner Richtung und entsprechendes Uberschreiben der nach Uber- 
schfeiten eiries n- dimens ionalen Arbeit swert interval 1 s nicht 
mehr dem aktuellen Arbeit swert interval! benachbarter Inter- 
valle ubertragen laEt und sclmtzrechtlich als iimfafit angese- 
hen wird. 

; 

i 

Die Erf indung wird im Folgenden nur beispielsweise anhand 
der Zeichnung beschrieben. In dieser zeigt: 

Fig.l den Gesamtaufbau eines erf indtmgsgemafi ausgiestal- 
teten Logikzellenarrays 

Fig. 2 eine detailliertere Ansicht hierzu mit als Clu- 
stern bezeichneten Teilarrays/ VPAEs dazwischeh 
und AnschluSbussen 

Fig. 3 ein Beispiel fur eiri Vorwartsregister eines Kon- 
f igurationsbusses 

Fig. 4 die Hierarchie von Konf igurationsmanagern eines 
erfindungsgemaS ausgestalteten Logikzellenarrays 

Fig. 5 Details einer PAE mit Angaben, welche Details in 
verschiedenen Voranmeldungen partiell zu entnehmen 
sind. Erkennbar sind die drei Dateeingange ABC 
in die Logikzelle, die funf Triggereingange fur 
den Triggervektor Reset Stop Step GO RELoad, die 
beiden Daten-Ausgange H(igh) und L(ow) sowie die 
Statussignalausgange UVW und ie Busauf kopplung 

Fig .6 a den Aufbau der Logikzelle im Blockbild 

Fig. 6b den Aufbau eines Registers 

Fig. 6c den Regis teraufbau eiens Ruckwartsregisters fur 
Eventsignale mit der hier neuen optionalen Nach- 
schautabelle 

Fig. 6d ein Vorwartsregister mit Vorladem6glichkeit 
Fig 7 den Detailaufbau einer Speicherzelle, die eine 
von datenverandernden Logikzellen (PAEs) unter- 
schiedlichen Eingang mit entsprechender anderer 
erforderlicher Busbreite aufweist 
Fig. 8 eine weitere Detailansicht eines Ruckwartsregi- 
sters im Konfigurationsbus mit Nachschautabelle 
fur die Implementierung boolscher Verknupfungen 
von Triggervektorbits 
Fig. 9 weitere Prozessordetails insbesondere der Busse 
Fig. 10 unsynchronisierte I/O Schaltung mit zwei Bussen 
Fig. 11 synchronisierte I/O Schaltung mit zwei Bussen 
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Nach Fig.l umfafit ein aligemein mit 1 bezeichneter Prozessor 
1, der eine als XPP (xtreme processing platform) bezeichen- 
bare Einheit bilden kann, 
zwei Felder oder Cluster 
5 -einer Anzahl von arithmetischen Logikzellen (ALU- 

PAEs=arithmetic logic unit processing array ele- 
ment) , . 
-Speicherzellen (RAM-PAEs= Random acces memory process- 
ing array element) 
10 -mehreren, dargestellt vier Eingangs-/Ausgangszellen 

(E/A-Elemente, Input -output -processing aray ele- 
ment) , 

-ein durch jedes Feld verlaufendes Bussystem, und 
-einen Konf igurationsmanager, der dem Feld zugeordnet 

15 ist, 

wcpbei diese Elemente zusammen als Cluster eine Einheit 
bilden, die fur sich in der Lage ist, Daten zu 
verarbeiten und zwar als rekonf igurierbare Einheit 
und wobei den beiden Konf igurationsmanagern (CM) der 

20 Cluster ein ubergeordneter Konf igurationsmanager 

(SCM) zugeordnet ist f urn so ein Ubercluster bzw. 
die XPP zu bilden, wobei erwahnt sei, daS es ins- 
besondere unter Ausnutzung baumartiger Hierarchie- 
strukturen moglich ist, mehr als zwei Felder von 

25 Prozessorelementen zusammenarbeiten zu lassen; so 

kann ein ubergeordneter Konf igurationsmanager mehr 
als nur zwei Konf igurationsmanagern (CM) uberge- 
ordnet sein, welche ihrerseits jeweils nur einem 
einzelnen PAE-Cluster zugeordnet sind, und/oder es 

30 kann vorgesehen sein, daS eine mehrstufige Konfi- 

gurationsmanager-Hierarchie aufgebaut isJt, worin. 
ersten, eigentlich dem Cluster zugeordneten Kon- 
f igurationsmanagern (CM) ein Konf igurationsmanager 
mittlerer Ebene zugeordnet ist und diese wiederum 

35 einer Oder mehreren Hierarchieebenen unterstehen. 

Fig. 1 gibt dabei die Anordnung der Zellen zueinander in ei- 
ner zweidimensionalen Matrix und deren relative GroSe nahe- 
rungsweise zumindest insofern korrekt wieder, als da£ die 

40 einzelnen Zellen sehr regelmafiig angeordnet sind und insbe- 
sondere die PAEs, also die speichernden und arithmetischen 
Logikzellen naherungsweise die gleiche GroSe besitzen, was 
es erlaubt, bei der aligemein rechteckigen und/oder regula- 
ren Zellstruktur mit annahernd gleicher Anbindung an das 

45 Bussystem eine Kachelung vorzunehmen; die gezeigte Kachelung 
ist dabei aber insbesondere insofern willktirlich hinsicht- 
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lich der Anordnung vori Speichern und Arithmetikeinheiten zu- 
einander, als daS andere Anordnungen, auch unter Miteinbe- 
ziehung der I/O-Zellen unci/ oder unter Verwendung noch ande- 
rer Elemente problemfrei moglich sind, und ohne weiteres an 
5 eirie gewunschte spezielle Rechenaufgabe anpaSbaf sind. Die 
gezeigte Darstellung ist auch insofern beispielhaft, als 
statt einer zweidimensionalen Matrix auch eine dreidimensio- 
nale Anordnung von Einzelzellen im Raum moglich ist, sofern 
die Herstellungstechnik der verwendeten Halbleitertechnolo- 
10 gie dies erlaubt. 

Eine einzelne PAE umfafit nun eine Vielzahl von Ein- und Aus- 
gangen. Dabei ist die einzelne PAE einerseits mit Datenein- 
und Ausgangen (A,B,C) versehen und andererseits mit Steuer- 
15 bzw. Kontrollein- und ausgangen (U,V,W) . wie aus Fig. l er- 
sichtlich, sind die PAEs in horizontalen Reihen angeordnet, 
wobei die Zellen untereinander uber ein Bussystem miteirian- 
der verbunden sind; diese horizontalen Bussystem sind in der 
Feldmitte verbunden mit den daruber bzw. darunter liegenden 
20 PAEs und zwar im gezeigten bevorzugten Beispiel nach oben 
und unten nur mit diesen. Damit erfolgt der Transfer von Da- 
ten und Statussignalen (d.h. Steuersignalen) nach oben und 
unten durch die PAEs hindurch und zwar bevorzugt wie darge- 
stellt in Fig. 1 unabhangig davon, urn welche Art von PAEs es 
25 sich handelt, also unabhangig davon, ob es sich im vorlie- 
genden Beispiel urn eine RAM-PAE oder eine ALU- PAE handelt; 
es sind demnach alle Sorten von PAEs bevorzugt auf die glei- 
che Weise an das Bussystem angeschlossen und intern entspre- 
chend verschaltet. Anders als dargestellt, ware es prinzipi- 
30 ell sogar moglich, auch die E/A-Zellen zur Verbindung uber- 
einander liegender Buslinien auszugestalten, was vorliegend 
allerdings unterblieben ist. 

Die PAEs dienen somit det Weiterleitung von Daten, also zu 
35 verarbeitende sowie Steuer- bzw. Kontrollf lufidaten in ver- 
tikaler Richtung. Die PAEs sind dabei so ausgebildet, da£ 
diese Weiterleitung unter Datenveranderung oder unverandert 
erfolgt. 

40 Die Datenveranderung kann zunachst in der eigentlichen Funk- 
tionseinheit der PAE erfolgen, z.B. wenn diese als arithme- 
tische Logikeinheit ausgestattet ist und Daten in der Arith- 
metikeinheit verknupft werden; urn sicherzustellen, daS Daten 
hinreichend schnell bereitgestellt werden, urn in der Zelle 

45 verknupft zu werden und eine optimale Ausnutzung der Zell- 
taktung zu bewirken, sind drei Leitungen A,B,C mit der Bit- 
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breite, die in der Zelle verarb^itet werden kanh, an die 
Zelle gefuhrt, vgl. Fig. 5. Dabei ist insbesondere auch eine 
bevorzugte additive E i ngang s ve r knup f ung moglich, was es er- 
laubt, mit der Zeile Ergebnisse Operationen der Art (A+B)*C 
5 zeit- und platzef f izient zu bestimmen . Wenn keine Datenver- 
anderung erf orderlich ist, konnen die Daten an der Funkti- 
onseinheit vorbeigeleitet werden. So konnen z.B; Daten, die 
in einer Reihe weiter unten benotigt werden, dorthin durch- 
geleitet werden, ohne einer Veranderung in der PAE unterwor- 

10 fen zu werden. Es sei erwahnt, dag bei der simultanen Zulei- 
tnng von z.B. drei Datenwortern entsprechend drei Eingange 
A, B, C diese unterschiedlich weitergeleitet werden konnen. 
So ist es z.B. moglich, nur das Datenwoirt auf Leitung C un- 
verandert weiterzuleiten, wahrend A und B in der ALU mitein- 

15 ander verknupft werden, z.B i durch Division A/B. Alternativ 
konnen auch zwei Datenworte an der ALU vorbeigeleitet wer- 
den, wahrend ein Datenwort in der ALU z.B. mit einer Kon- 
stanten oder einem dort zwischengespeicherten anderen Wert 
verknupft wird. Die Ubertragbarkeit auf andere Datenwortraen- 

20 gen, die simultan der PAE zugeleitet werden, ist offensicht- 
lich, d.h. es konnen auf Wunsch auch z.B. mehr als drei Da- 
tenworte an die PAE gefuhrt sein; das einzelne Wort hat da- 
bei die prozessorspezif ische Bitbreite, vorliegend z.B. 32 
Bit. 

25 Beliebige Eingange und/oder Ausgange von PAEs konnen mit 

Konstanten von der Konf igurationseinheit (CT / CM) konfigu- 
riert werden. Dabei konnen Konstante wahrend des gesamten 
Betriebs einer Konf iguration unverandert konstant bleiben 
oder wahrend des Betriebs d.h. der Ausfuhrung einer Konfigu- 

30 ration. von neuen Daten der Konf igurationseinheit (CT/CM) 

und/oder anderer Quellen wie z.B. PAEs uberschrieben werden.. 

Auch ist einsichtig, daS anders als bei PAEs mit ALUs etwa 
in RAM- PAEs statt einer Verkmipfung aller oder eines Teils 
35 der Daten eine vollstandige oder partielle Speicherung 

und/oder eine vollstandige oder partielle Weiterleitung er- 
folgen kann. 

Die Weiterleitung der Daten kann des weiteren unter Umgehung 
40 der eigentlich datenverandernden PAE-Kern-Einheit wie der 
ALU dergestalt erfolgen, dafi dennoch eine Veranderung der 
Daten vor bzw. wahrend der Weiterleitung erfolgt. Dies kann 
durch Veranderung der Daten unter Heranziehung von Nach- 
schautabellen und anderen Verknupfungseiixheiten geschehen, 
45 z.B. Einheiten, die die eintref f enden Datenworte der GroSe 
nach sortieren. Diese Einheiten sind bevorzugt zwischen die 
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Busankopplung und den Eintritt in die PAE-kern-Einheit ange- 
ordnet und in ihrer Funktion konf igurierbar, wodurch inse- 
. sondere konf igurierbar ist, ob die Daten unyerandert weiter- 
geleitet werden oder nicht; wenn sie nicht unverandert, son- 
5 dern verandert weitezgeleitet werden, ist konf iguriert , " wie 
innerhalb der gegebenen Moglichkeiten die Ver&nderung er- 
folgt. Besonders wichtig ist dabei fur die Status signalwei- 
terleitung das vorsehen von Nachschautabellen, da mit die'sen 
im Ansprechen auf vor£estimmte Eingangssignale ohne weiteres 
10 vorgegebene Ausgangssignale erzeugbar sind. 

Weiter kann die Datenweiterleitung auch uriveranderter Daten 
konf igurierbar sofort oder registerverzdgert erfolgen. Die 
dargestellte einzelne PAE hat zu diesem Zweck je ein konfi- 

15 gurierbar zuschaltbares Vorwarts- und ein konf igurierbar zu- 
schaltbares Ruckwartsregistex fur die zu verarbeitenden Da- 
ten und je ein konf igurierbar zuschaltbares Vorwarts- und 
ein konf igurierbar zuschaltbares Ruckwartsregister ftir Steu- 
erdaten, d.h. Triggervektoren bzw.Statussignale und/ oder 

20 Kontrollf luSdaten; es sei darauf hingewiesen, daJS Register 
mit erhohter (Zwischenspeicher-) Tief e insbesondere als FIFO- 
Register vorsehbar waren, etwa um Daten mehrtaktig zwischen- 
zuspeichern. Den jeweiligen Registern ist ein konf igurierba- 
. rer Multiplexer zugeordnet, mit welchem das jeweilige Regi- 

25 ster wahlweise in den Datenweg geschaltet werdeii kann oder 
aus ihm entfernt. Auch sind die Multiplexer dazu konf igu- 
rierbar, Ergebnisse aus der Zelle wie erwunscht und erfor- 
derlich auf die Busse zu schalten. So konnen z.B. das obere 
und untere Bitwort, das bei einer Mult iplikat ion erhalten 

30 wird, ausgegeben werden (H,L) und/oder es wird nur ein Er- 
gebnisdatenwort (H) ausgegeben und ein Datenwort (A) weiter- 
geleitet und auf den Bus ausgegeben, wobei sogar eine ge- 
wunschte Vertauschung (A<->H) konf iguriert werden kann. 
Damit ist eine PAE im vorliegenden Prozessormodell, und dies 

35 sei in seiner Bedeutung herausgestellt, charakterisiert 

durch eine Struktur, die eine Zentral-Funktionalitat besitzt 
wie eine ALU, ein RAM und/oder z.B. auch ein FPGA und die 
weiter Datenweiterleitungsfunktionalitat besitzt, wobei sie 
bevorzugt eine Vorwarts- und/odelr Ruckwartsregisterdatenwei- 

40 terleitungsfunktionalitat besitzen kann, also dann aus drei 
Basismodulen, namlich dem Zentralfiinktionalitatsmodul wie 
FPGA, ALU, RAM und den zwei (Vorwarts- /Ruckwarts-) Regi- 
sterdatenweiterleitungsfunktionalitatmodulen besteht, wobei 
diese letzteren Zusatzfunktionen implement ier en konnen. Zen- 

45 tralfunktionalitat bedeutet dabei nicht raumliche Zentral- 
funktionalitat, sondern Funktionalitat im Sinne von Abstel- 
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len auf die zentrale Bedeutung und Wirkung der jeweiligen 
PAE. Die Zusatzfunktionen, die durch die Registerdatenwei- 
terleitungsfunktionalitatmodule implement iert sind, umfassen 
insbesondere bevorzugt im Vorwartsregister fur den DatenfluS 
5 Kontrollbperationen wie das Mult iplexen oder Pemultiplexeh 
sowie das Kopieren und/oder andere Manipulieren von Daten; 
im Rtickwartsregister wird bevorzugt implement iert eine ALU- 
Funktionalitat fur den DatenfluS und/oder eine Boolsche Ver- 
knupfung von Eventsigpalen, d.h. Triggers ignalen. Somit be- 
10 steht die PAE aus Modulen zur Manipulation von Datenstromen, 
zur operativen Verknupfung und/oder Generierung von Datenpa- 
keten sowie aus der Verarbeitung durch zumeist logische Ver- 
knupfung und Generierung von Eventpaketen. 

15 Die Ein-Ausgabembdule sind in ihrer Struktur gleichfalls in 
besonderer Weise an die Anf orderungen der Datenverarbei- 
tungsaufgabe angepafit . Dazu iist jedes der Ein-Ausgabemodule 
mit mehreren Kanalen versehen, die unabhangig voneinander im 
sog. PORT-Modus (Fig. 10) arbeiten konnen oder in Synchroni- 

20 sation zueinander im sog. RAM-Modus (Fig. 11) arbeiten kon- 
nen. Jedes E/A-Modul kann dabei von mehreren Algorithmen un- 
ter Verwendung mehrerer Algorithmen gleichzeitig verwendet 
werden, wozu auch Sortieralgorithmen herangezogen werden 
konnen . 

25 

Mit anderen Worten arbeitet im Speicher- (RAM) -Modus (Fig. 11) 
das Ein/Ausgabemodul (I/O Schnitts telle) als Schnittstelle zu 
externem Speicher. Es werden dabei Schreibedaten und Adress- 
daten eines jeden Kanals synchronisiert, d.h. erst wenn. bei- 
30 de Datenpakete vorhanden sind, wird ein externer Schreibvor- 
gang gestartet. Im Lesemodus sortiert die EA Einheit von ex- 
tern gesendete Pakete wieder an die internen KancLle. Die Um- 
schaltung zwischen Schreib- und Lesemodus kann: z.B. per Kon- 
figuration oder z.B. durch Signale erf olgen. 

35 
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PCT-Anmeldung "Verfahren und Vorrichturig" 



10 



-Patentanspruche 
15 . ■ ... • . ; 

1. Logikzellenanordnung mit einer Anzahl Logikzellen und 
einem segment iert en Bus system f \ir die Logikzellenkommu- 
nikation, 

dadurch gekennzeichnet , dafi 
20 das Bussystem unterschiedliche Segment linien mit kurze- 

ren und langeren Segmenten zur Verbindung zweier Punkte 
umfaSt, urn die Anzahl zu durchlauf ender Buselemente bei 
auseinander beabstandeten Kommunikationsstart- und End- 
punkten gering halt en zu kdnnen. 

25 

2. Logikzellenanordnung nach dem vorhergehenden Anspruch, 
dadurch gekennzeichnet, da£ die Segment linien jeweils 
aus einer Mehrzahl paralleler Leitungen gebildet sind, 
deren Anzahl durch die Bus-Breite und/oder das Buspror 

30 tokoll bestimmt ist. 

3. Logikzellenanordnung nach einem der vorhergehenden An- 
spriiche, dadurch gekennzeichnet, daS datenverahdernden 
Logikzellen drei der fflr die verarbeitete Bitbreite er- 

35 forderlichen Leitungsbuhdel als Datenzuftihriingsleitun- 

gen zugefuhrt sind. 

4. Logikzellenanordnung nach einem der vorhergehenden An- 
sprtiche, dadurch gekennzeichnet, daS von datenveran- 

40 dernde Logikzellen zwei der fur die verarbeitete Bit- 

breite erforderlichen Leitungsbundel fvir Daten wegge- 
fuhrt sind, insbesondere mit einem Leitungsbiindel fur 
hdherwertige und einem Leitungsbundel fur niederwerti- 
gere Bits. 



45 



Logikzellenanordnung insbesondere nach einem der vor- 
hergehenden Ansprfiche, dadurch gekennzeichnet, da£ bei 
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rekonf igurierbaren Logikzellen an deren Steuereing&nge 
Leitungsbiindel gefuhrt sind, die derart angeordnet 
, sind, daE wenigstens Signale in die Zelle ubertragbar 
sind, die alternativ wenigstens eine Art der Aktivie- 
rung (Step/ Stop; Go) , ein Zurilcksetzen (Reset) und ein 
Rekonf igurieren (Reload) bewirken konnen. 

6. Logikzellenanordnung nach ei'nem der vorhergehenden An- 
spruche , * * i 

dadurch gekennzeichnet, daS 
das Bussystem Segmente zur Verbindung der Logikzellen 
-untereinander und/oder mit 

- internen und/oder externen, die Logikzellen 
-konf igurierenden und/oder rekonf igurierenden 
Einheiten, und/oder 
-I/O-Schnittstellen und/oder 

zur Logikzellenanordnung externen Datenspeichern 
umf aSt . 

1. Logikzellenanordnung nach einem der vorhergehenden An- 
spruche, dadurch gekennzeichnet, da6 
das Busystem neben Leitungen weiter Leitungszwi- 
schenelemente umfaSt, 
insbesondere zumindest eines der Buselemente 
Verbindungs-Schalter, 
Multiplexer, 
Register, 

insbesondere algebraisches verkniipf endes Regi 

ster, 

insbesondere addierendes und/oder multiplizie 
rendes Register, 

insbesondere nur zwei Operanden algebraisches 
veirknupf endes Register 

Logikverkniipfungsschaltungen boolscher Art, 

insbesondere Nachschautabellen, und/oder 
Lei tungstreiber . 

8. Logikzellenanordnung nach dem vorhergehenden Anspruch, 
worin Logikverkniipfungsschaltungen als Buselemente vor- 
gesehen sind, dadurch gekennzeichnet, dafi die Logikver- 
knupfungsschaltungen von einer Logikzellenrekonf igurie- 
rungseinheit, insbesondere einer Konf igurationsmanagin- 
geinheit und/oder einer Logikzelle beschreibbar ist. 

9. Logikzellenanordnung nach einem der vorhergehenden An- 
spnlche, dadurch gekennzeichnet, daE Ubergangsmoglich- 
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keiten von einem Segment einer ersten Segmentlinie auf 
ein Segment einer zweiten Segmentlinie vorgesehen sind. 

10 . Logikzellenanordnung nach einem der vorhergehenden An - 
5 spruche , dadurch gekennzeichnet, daS das Bussystem eine 

Vielzahl von parallelen Segmentlinien umfaSt, wobei : 
mehrere parallele Segmentlinien mit linger en Segmenten 
vorgesehen sind. 

10 11. Logikzellenanordnung nach dem vorhergehenden Arispruch, 
dadurch gekennzeichnet, daS 

ftir unterschiedliche der Mehrzahl an parallelen 
Segmentlinien mit langeren Segmenten 

die Segment linienenden und/oder Leitungszwi- 
15 schenelemehte in d<en Segmentlinien 

in Busrichtung versetzt gegeneinander angeordnet sind, 
insbesondere urn jeweils mindestens eine Logikzelenein- 
heit versetzt. 

20 12. Logikzellenanordnung nach dem vorhergehenden Anspruch, 
dadurch gekennzeichnet, dafi bei wenigstens drei Seg- 
mentlinien mit ISngeren Segmenten fflr wenigstens zwei 
Segmentlinien bei vorgegebenen Stellen Segment 1 in i en - 
wechselkreise, insbesondere Multiplexer, als Leitungs- 

25 zwischenelemente vorgesehen sind, 

13. Logikzellenanordnung nach dem vorhergehenden Anspruch, 
dadurch gekennzeichnet, daS die Segment linienwechsel- 
kreise fttr den Wechsel von einer ersten auf eine zweite 
30 , Segmentlinie an einer ersten Stelle und die Segment li- 

nienwechselkreise fur den Wechsel von einer zweiten auf 
eine dritte Segmentlinie an einer zweiten Stelle vorge- 
sehen sind.. 

35 14. Logikzellenanordnung nach dem vorhergehenden Anspruch, 
dadurch gekennzeichnet, daS zumindest ein Segmentlini- 
enwechselmultiplexer vorgesehen ist, der den Ubergang 
von einer Segmentlinie auf wenigstens eine wahlweise 
einer Vielzahl von Segmentlinien erm6glicht. 

40 

15. Logikzellenanordnung nach dem vorhergehenden Anspruch, 
dadurch gekennzeichnet, daS getrennte Busanordnungen 
fur entgegengesetzte Lauf richtungen ausgebildet sind, 
wobei fiir wenigstens eine Laufrichtung unterschiedliche 
45 Segmentlinien mit, kiirzeren und langeren Segmenten vor- 

gesehen sind. 



23 



WO 02/29600 



PCT/EP01/11593 



16. Logikzellenanordnung nach dem vorhergehenden Anspruch, 
dadurch gekennzeichnet, daS bei getrennten Segmentlini- 
en fur beide Lauf richtungen und fur wenigstens eine 
Laufrichtung Register vorgesehen sind. 

17. Logikzellenanordnung nach d^m vorhergehenden Anspruch, 
dadurch gekennzeichnet, daS Register in rtickwcirtsge- 
fuhrten Bussystejnen vorgesehen sind, d.h. Bussystemen, 
mit denen Signale von einem Elementausgang zu einem 
Elementeingang zurxickgefiihrt werden konnen. 

18. Logikzellen nach einem der vorhergehenden Anspruche , 
dadurch gekennzeichnet, da£ wahlweise zuschaltbare Re- 
gister zwischen zumindest zwei Segment en wenigstens ei- 

". ner* Segment linie vorgesehen sind. 

19. Logikzellen nach dem vorhergehenden Anspruch, dadurch 
gekennzeichnet, da£ wenigstens ein wahlweise zuschalt- 
bares Register in einem vorwartsgefuhrten Register vor- 
gesehen ist. 

20. Logikzellen nach dem vorhergehenden Anspruch, dadurch 
gekennzeichnet, worin ein Mittel vorgesehen ist, urn das 
Register bei Ausfuhrung eines Programmes ' nach Wahl des 
Compilers zuzuschalten. 

21. Logikzellenanordnung insbesondere nach einem der vor- 
hergehenden Anspruche, dadurch gekennzeichnet,* daS ein 
erstes Bussystem fur die Ubertragung zu bearbeitender 
Daten und ein zweites Bussystem fur die libertragung von 
Status-, und/oder Kontroll-bzw. Steuerinformation vorge- 

• sehen ist 

22. Logikzellenanordnung nach dem vorhergehenden Anspruch, 
dadurch gekennzeichnet, daS wenigstens bei einem der 
Bussystem unterschiedliche Segmentlinien mit parallelen 
kurzeren und langeren Segmenten zur Verbindung zweier 
Punkte vorgesehen sind, urn bei auseinander beabstande- 
ten Logikzellen die Anzahl zu durchlaufender Buselemen- 
te gering halten zu konnen. 

23. Logikzellenanordnung nach einem der vorhergehenden An- 
spruche, dadurch gekennzeichnet, daS wenig£tens eine 
Reihe mit wengistens drei Logikzellen vorgesehen ist 
und die l&ngeren .Segmente an wenigstens einer Logikzel- 
le vorbeigefuhrt sind. 

i i 
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24. Logikzellenanordnung nach einem der vorhergehenden An- 
spruche, dadurch gekennzeichnet, daS wenigsteriB eine 
Reihe mit mehr als drei Logikzellen vorgesehen ist und 

5 die l&ngsten Setjmente ah mehr als ; e irie r Logik z e 1 1 e voir- 

, beigefiihrt sind. 

25. Logikzellenanordung nach einem der vorhergehenden An- 
spruche, dadurch gekennzeichnet, daS die Logikzellen 

.10 ausgewahlt sind aus, urafassen und/oder bilden Rechen- 

werke, DPGAs , Kress -Arrays, systolische Prozessoren und 
RAW-Machines; digitale Signalprozessoren (DSPs) , die 
mehr als ein Rechenwerk besitzen, konf igurierbare (pro- 
grammierbare) Logikzellen oder andere Cores und/oder 

15 PAEs , ALU, Eingabe- / Ausgabef unktionen (I/O) und Spei- 

chermanagementeinheiten (1/6) , Speicher. 

26. Prozessor mit einer Vielzahl unterschiedlicher, in ei- 
nem Array angeordneter kommunizierender Logikeinheiten, 

20 dadurch gekennzeichnet, dafi 

die Logikeinheiten wenigstens Speicher- und Datenveran- 
derungseinheiten aufweisen und die Speichereinheiten 
randnah am Array angeordnet sind. 

25 2 7. Prozessor nach dem vorhergehenden Anspruch, dadurch ge- 
kenr eichnet, dafi allenfalls Eingang/Ausgangseinheiten 
n&hef am Rand als die Speichereinheiten angeordnet 
sind. 

30 28. Prozessor nach dem vorhergehenden Anspruch, dadurch ge- 
kennzeichnet, daS zur Kommunikation der Logikeinheiten 
wenigstens. von Rand zu Rand wenigstens ein Bussystem 
vorgesehen ist. 

35 29. Prozessor nach dem vorhergehenden Anspruch, dadurch ge- 
kennzeichnet, dafi die Speichereinheiten am Rand des 
Bussystems angeordnet sind. 

30. Prozessor nach einem der vorhergehenden Anspruche, da- 
40 durch gekennzeichnet, dafi mehrere miteinander in Kommu- 
nikation bringbare insbesondere identische Arrays vor- 
gesehen sind. 

31. Verfahren zum Betrieb eines Prozessors nach einem der 
45 vorhergehenden Anspruche, dadurch gekennzeichnet, dafi 

Daten aus einem ersten, insbesondere randnahen Speicher 
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ausgelesen und in einer erste, diesem Speicher nahe Da- 
tenveranderungseinheit wie erforderlich verandert wer- 
den> insbesondere von dort in wenigstens eine weitere 
Datenveranderungseinheit tibertragen werden,- urn weitere 
Dateriver&nderungen wie erforderlich vorzunehmen, die 
Paten nach Durchlauf en einer oder mehrerer Datenveran- 
deriingseinheiten in einen zv/eiten Speicher an einer vom 
ersten Speicher insbesondere entfernten Stelle einge- 
speichert werderv, eine Umkof igurierung der Datenveran- 
derungseinheiten zur Neubestimmung der Datenveranderung 
vorgenommen wird, wonach insbesondere mdglich ist, daS 
. die so verlLnderten und/oder erzeugten Daten neuer- 
lich 

insbesondere in entgegengesetzter Laufrichtung und 
insbesondere durch zumindest einen Teil der Daten- 
veranderungseinheiten 
geffihrt werden. 

32. Verfahren zum Betrieb eines Prozessors nach einem der 
vorhergehenden Anspruche, dadurch gekennzeichnet , wobei 
der Hinlauf in einer Reihe erfolgt und der Riicklauf in 
der bzw. einer darunter liegenden Reihe, urn so Pipeli- 
neeffekte zu berucksichtigen. 

33. Prozessor insbesondere nach einem der vorhergehenden 
Ansprtiche mit einem wenigstens zweidimensionalen Array 
unterschiedlicher Datenver&nderungseinheiten, die we- 
nigstens eine programraierbares Gatterfeld (PGA) und 
mehrere Datenveranderungseinheiten mit ALUs aufweisen, 
dadurch gekennzeichnet, daS das wenigstens eine oder 
mehrere PGAs von anderen Datenveranderungseinheiten, 
insbesondere ALUs umgeben sind. 

34. Prozessor insbesondere nach einem der vorhergehenden 
Anspriiche, mit miteinander in Kommunikation bringbaren 
insbesondere identische Arrays, die umkonf igurierbare 
Datenveranderungseinheiten und eine Umkonf igurierungs- 
einheit aufweisen, 

dadurch gekennzeichnet, daS 

jedem Array eine Umkonf igurierungsverwaltungseinheit 
zugeordnet ist, 

die insbesondere an einer Arrayseite angeordnet 
ist, an welcher keine Speicher- und/oder I/O-Einheiten 
vorgesehen sind, 

wobei sich d;Le Umkonf igurierungseinheit bevorzugt 
uber die Breite des Arrays erstreckt. 
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35. Prozessor nach einem der yorhergehenden Anspriiche , da- 
durch gekennzeichnet, daS eine den Arrays gemeinsame 
Umkonf igurierungsverwaltungsfibere^ vofgesehen ist, 
die sich insbesondere fiber die Breite von mehr als ei- 
nem Array erstreckt und die fur die Kommunikation mit 
zumindest mehreren, bevbrzugt alien der Umkonf igurie- 
rungsfiberienheiten ausgelegt ist. 

:" l 

36. Prozessor mit miteinander in Kommunikation bringbaren 
insbesondere identische Arrays, die umkonf igurierbare 
Patenver&nderungseinheiten aufweisen, wobei zwischen 
den Arrays Vermittlungseinheiten (VPAEs) vorgesehen 
sind, die zur KommunikationsvezTrciittlung angeordnet 
sind. 

37. Prozessor nach dem vorhergehenden Anspruch, dadurch ge- 
kennzeichnet, daS die Konf igurationseinheiten von we- 
nigstesn zwei der Arrays direkt in Verbindung miteinan- 
der stehen, insbesondere fiber dedizierte Festleitungen 
und/oder fiber beim Booten vorkonf igurierte Datenleitun- 
gen. 

38. Prozessor ndch einem der beiden vorhergehenden Ansprii- 
che, dadurch gekennzeichnet , dafi die Vermittlungsein- 
heiten (VPAEs) zwei Konf igurationsregister aufweisen, 
wobei das erste Konf igurationsregister vom ersten Array 
und das zweite Konf igurationsregister vom zweiten Array 
ansprechbar iist, urn so ein schleusenartiges Ubertragen 
von Daten durch die VPAEs zu erm6glichen. 

39. Prozessor insbesondere nach einem der beiden vorherge- 
henden Anspriiche, dadurch gekennzeichnet, da£ 

die Arrays fiber eine Reihe Datenverande rungs- und/oder 
transfereinheiten (VPAE) miteinander in Komunikatidn 
bringbar sind. 

40. Prozessor nach dem vorhergehenden Anspruch, dadurch ge- 
kennzeichnet, daS die kommunikationsermdglichendeji Da- 
tenverSnderungseinheiten beidseits fiber langs des 
Arrays verlaufende Busse an das Array verbindbar sind, 
wobei die Busse insbesondere fiber den Arrayrand hinaus- 
laufend ausgebildet und dort insbesondere weiter zu 
I/O-Schnittstelleneinheiten ffihrbar sein konnen. 
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41. Prozessor nach dem vorhergehenden Anspruch,. dadurch ge- 
kennzeichnet , daS an den Array- AuSenrandern, die nicht 
an Nachbararrays angrenzen, langs des Arrays verlauf en - 
de Busse an das Array Vorgesehen sind, die insbesondere 
fiber den Arrayrand hinauslauf end ausgebildet und dort 
insbesondere weiter zu I/O-Schnittstelleneinheiten 
fuhrbar sind. 

42 . Prozessor insbesondere nach einem der vorhergehenden 
Anspruche mit einer umkonf igurierbaren Datenverande- 
rungseinheit , die von Daten in einer durch I/O- 
AnschlClsse yorgegebenen Richtung durchstrdmt ist, wobei 
die Daten dadurch gekennzeichnet , daS ein Vorw&rtsregi- 
ster zur Datenweiterleitung iru Ansprechen auf vorgege- 

bene Ereignisse vorgesehen ist. 

*• 

43. Prozessor nach einem der vorhergehenden Ansprxiche, da- 
durch gekennzeichnet, dafi ein Datenweiterleitungsrege- 
1 implement ierungsmittel, insbesondere eine Nachschauta- 
belle vorgesehen ist, das zur Ermoglichung der Daten- 
weiterleitung im Ansprechen auf die gemeinsame Erful- 
lung einer Vielzahl von Kriterien, 

insbesondere ereignisbezogener Kriterien ausgebil- 
det ist, 

bei Auslegung des Arrays mit reihenweise angeord- 
neten Da tenverande rungs-, und/oder . - 

verknupfungseinheiten insbesondere auf die gemneinsame 
Erfttllung einer Vielzahl von in einer Reihe erfiillten 
Kriterien. 

44. Prozessor insbesondere nach einem der vorhergehenden 
Anspriiche wobei Datenyeranderungseinheiten und Daten- 
speichermittel vorgesehen sind, dadurch gekennzeichnet, 
daS zumindest einigen der Datenveranderungseinheiten 
Datenspeichfermittel lokal zugeordnet sind, und insbe- 
sondere Mitt el vorgesehen sind, um in die lokalen Da- 
tenspeichermittel iokal eingeschriebene Daten zur loka- 
len neuerlichen DatenverSnderung lokal auszulesen. 

45. Prozessor mit einer Mehrzahl umkonf igurierbarer Lo- 
gikzellen, wobei 

wenigstens eine und bevorzugt eine Vielzahl von Lo- 
gikzellen 

wenigstens einen Eingang zum Zurticksetzen der Lo- 
gikzelle (Reset) , 

wenigstens einen Eingang zum Umkonf igurieren der 



28 



WO 02/29600 



PCT/EP01/11593 



Logikzelle (Rekonfig) und 

wenigstens einen Eingang uhd bevorzugt mehrere 
Eingange zum Aktivieren der Logikzelle (Step, Stop, Go) 

und/oder worin die Vielzahl von Zellen 

Statuseingange aufweisen, welche dazu ausgelegt 
sind, angelegte Status -Eing^ngssigrialezu unterscheiden 
in 

wenigstens einen Eingangsstatus zum Zurucksetzen 
der Logikzelle (Reset) , 

wenigstens einen Eingangstatus zum Umkonf igurieren 
der Logikzelle (Rekonfig) und 

wenigstens einen Eingang zum Aktivieren der Logkizelle 
(Step, Stop, Go) . 

46. Verfahren zur Umkonf igurierung eines Zellarrays aus im 
Betrieb rekonf igurierbaren Logikzellen, wobei die Um- 
. konf igurierung im Ansprechen auf die Propagation be- 
stimmter vorgegebener Daten erfolgt, dadurch gekenn- 
zeichnet, da& auswahlbar ist, 
ob die Rekonf igur at ion 

fur alle Logikzellen erfolgt, die von den vorgege- 
benen und/oder daraus hergeleiteten' Daten angestromt 
werden 
und/oder 

nur ftir einen Teil, insbesondere einen Verarbei- 
tungszweig (zB einen if -then-Zweig) , w&hrend wenigstens 
ein anderer Zweig unverSndert bleibt, 

und/oder nur eine Teilkette einer l&ngeren Reihe 
von naqheinander Daten verarbeitenden Logikzellen 
isnhesbdnere bis zu einer vorgegebenen Logikzelle, 
und/oder, 

urn die Rekonf iguration sofort oder nach der bzw. 
einer weiteren Datenverarbeitung zu gestatten und 
eine solche Auswahl vorgenommen wird. 

47* Verfahren zur vorladbare Logikeinheiten verwendenden 
Approximation des Verhaltens nichtlinearer Systeme, 
insbesondere unter Verwendung von Logikzellenanordungen 
nach einem der vorhergehenden Ansprxiche, dadurch ge- 
kennzeichnet , dafi 

fiir eine Reihe aneinander angrenzender Arbeitsbe- 
reiche jeweilige geeignete Approximationen bestimmt 
werden, \ 

zu einem augenblicklichen Arbeitsbereich (n) sowie 
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zu dessen unten und oben ((n-1), (n+1)) angrenzenden 
Arbeitsbereichen die Approximationen ermoglichenden Pa- 
rameter vorgeladen werden, 

das Verhalten mit dem mittleren (n) Arbeitsbereich 
approximiert wird, bis der Arbeitsbereich, inrierhalb 

. dessen die Approxim«ation geeignet ist, uberschritten 

■ wird, j>- : 

dann mit jener der Approximation (n-1) weiter gearbei- 
tet wird, welche^ zu dem Arbeitsbereich gehort, in wel- 
chen hinein die Uberschreitung erfolgte und bevorzugt 
die Approximation zu jenem Arbeitsbereich (n+1) , 
in welchen hinein die Uberschreitung nicht erfolgte, 
uberschrieben wird mit einer Approximation (n-2) , die 
gemeinsam mit der zuvor verwendeten Approximation (n) 
die derzeit verwendete Approximation (n-1) bzw. die zu- 
gehorigen Arbeitsbereiche umklammert. 
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Figure 1: The overall structure of an XPU: 
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The Supervising Configuration Manager (SCM) controls configurations from external RAM or ROM and reacts on external 
trigger events and IDs. The SCM communicates with both PAC Configurafions Manager (CM). Both CMs are responsible to 
load configurations into the PAC array and to react on triggers from PAC array. 



WO 02/29600 



5/11 



PCT/EP01/11593 





WO 02/29600 



6/11 



PCT/EP01/11593 



\ 32 StOata input K 



I- < 
< ca O cc to coo en 



1 Ba Event Line 



mput Register: 
Date pcetoad 



Arithmetic unit 



ALU Oata output 




vr 



^ V V YtYtY 


A B C 




- ALU 






u V w 


H t 





I 



lr „ n v 



optional Event 



ALU Event 
outputs 



v ir u 




32 Sit Data 



1 Forward Register 



oc oc a: <e o O 



Forward register for roulinaof Data and Events from foe upper to lower routing segment 



WO 02/29600 



7/11 



PCT/EP01/11593 



32 89 Data Uriel 



optional: 
Ql »01 + 
03 
or 

Q1-01-D3 



regeSsteredoffeed 
through Data 8REG 



kiput Register 
Data vafae preload to 
registered mode 



o S S'2 2'S 



JUL 



ni TTT 1 




V 



PAC Forward Register (ppFg T" — * 

^ objects connect PACO and PAC1. One PFR has "4 down data connections (from PA, 



o fi v cd a) i= 



Q Q O 



WTO to 



v w v v i M n M ' 



B'fiZtlgg o o 3 8 



Input Register: ' 
Data value preload 



WO 02/29600 



8/11 



PCT/EP01/11593 





WO 02/29600 



9/11 



PCT/EP01/11593 




WO 02/29600 



10/11 



PCT/EP01/11593 




WO 02/29600 



11/11 



PCT/EP01/11593 



EA-Modul 



P3 



P2 



PI 



P3 



P2 



PI 



EA Kanal 1 



o 
o 
o 



EA Kanal n 



15 

20 

Kanal 1 

25 
30 

Kanal n 

. 35 



Figur 10. 
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